// 基于axios封装，网络请求的函数
import axios from 'axios'
import store from '@/store'
import router from '@/router'

export const baseURL = 'http://big-event-vue-api-t.itheima.net' // 接口和图片资源所在的服务器地址
// axios.create()创建一个带配置项的自定义axios函数
// myAxios请求的时候，地址baseURL+url，然后去请求后台

const myAxios = axios.create({
  baseURL: baseURL // 域名
})
// 定义请求拦截器
// api里每次调用request都会先走这个请求拦截器
myAxios.interceptors.request.use(function (config) {
  // 为请求头挂载 Authorization 字段
  // 在请求前会触发一次 这个return交给axios源码内 根据配置项发起请求
  // 它返回给axios内源码 config配置对象（要请求后台的参数都在这个对象上）
  // 在发起时 统一携带请求头Authorization和token值
  // 判断登陆页面和注册页面 vuex里无token 而且登录接口和注册接口也不需要携带token（其他页面需要）
  if (store.state.token) {
    config.headers.Authorization = store.state.token
  }
  return config
}, function (error) {
  // 请求发起前的代码 如果有异常报错 会直接进入这里
  // 返回一个拒绝状态下的Promise对象
  // 也就是axios留在原地的Promise对象状态就为失败 结果为error变量值
  // 所以此函数类似于catch函数（）里的return
  // 口诀：return非Promise对象值 会作为成功的结果 返回给下一个Promise对象即axios留在原地的那个
  // 口诀：return的是Promise对象 这个Promise对象状态 返回给下一个Promise对象
  // Promise.reject()原地留下一个新的Promise对象（状态为失败） 它是Promise的类方法reject（）
  return Promise.reject(error)
  // 等同于return new Promise((resolve,reject))=>{reject(err)}
})
// 定义响应拦截器
myAxios.interceptors.response.use(function (response) {
  // 响应状态码为 2xx 时触发成功的回调，形参中的 response 是“成功的结果”
  // return 到axios原地axiosPromise对象 （即逻辑页面）作为成功的结果
  return response
}, function (error) {
  // 响应状态码不是 2xx 时触发失败的回调，形参中的 error 是“失败的结果”
  // return 到axios原地axiosPromise对象位置（即逻辑页面） 作为失败拒绝的状态
  // 如果那边用try+catch或者catch函数捕获 可以捕获我们传递过去的这个error变量值
  // 去破坏localStorage里的值 刷新让vuex取出来错误的token 导致401
  if (error.response.status === 401) {
    // 本次响应token过期了
    // 清除vuex里的一切 然后切换回到登陆页面（被动退出登录状态）
    store.commit('updateToken', '')
    store.commit('updateUserInfo', {})
    router.push('/login')
  }
  return Promise.reject(error)
})
// 导出axios自定义的函数
export default myAxios
